草庐IT

Java 改变变量名改变程序行为

全部标签

ruby-on-rails - 是否可以在 ruby​​ 中取消定义变量?

在ruby​​中,有没有办法在变量或常量定义后“取消定义”?在我们的rails环境中,我们将三个常量之一定义为true,具体取决于环境:TESTING、DEVELOPMENT或生产。然后,在Controller代码中,我们使用defined?来查看我们是否处于什么环境中,即:defined?制作。现在,我想对某些特定于环境的行为进行单元测试。我最初的尝试是在我的测试中设置适当的常量,然后在拆卸时重置它们。但是,我不知道如何重置DEVELOPMENT和PRODUCTION以便defined?返回false。显然,解决方案是除了检查适当的常量是否已定义之外,还检查它是否也为真,但这将导致不

ruby-on-rails - 我应该为这个网站应用程序使用 Rails 还是 Ruby?如何?

我对网络编程还很陌生(或者实际上,对网络编程很陌生,因为我上次弄乱网络是HTML1.1),但现在需要快速部署网络应用程序。似乎每次我转身,都有新的首字母缩略词和技术需要学习(JSON、XMLRPC、GWT、Javascript、Rails等)。这是我的应用必须执行的操作:给定用户名和密码,进行身份验证(很简单,显然一切都这样做)。允许用户上传大量数据进行处理。处理该数据。允许用户下载他们处理过的数据。我已经有了用于处理数据的Java脚本和数据库。在一台机器上,我可以运行一系列命令行程序来处理传入的数据block并将结果放回mysql数据库。这已经存在并且有效。我想为这个任务构建一个网络

ruby - 部署 Rack 应用程序的可靠方法 (Sinatra)

我正在寻找一种可靠的方式来部署Rack应用程序(在本例中为Sinatra应用程序)。请求将花费一些时间(0.25-0.5秒等待代理HTTP请求)并且可能会有相当大的流量。我应该使用传统的mongrel集群设置吗?使用HAProxy作为负载均衡器?恩金克斯?架子?您使用过哪些解决方案,有哪些优势? 最佳答案 Nginx/unicornFTW!前面的Nginx提供静态文件和unicorn处理Sinatra应用程序。优点:性能、使用unixsocks的良好负载平衡以及无需停机即可部署/升级(您可以在不停机的情况下升级Ruby/Nginx/

ruby-on-rails - 我的 Rails 4 应用程序上的每个 link_to 都被调用了两次

我的Rails4应用程序遇到一些异常行为。每次我单击View中的link_to时,我的Controller操作都会被调用两次。例如:在我的root_url中,我对users_profile有这个标准调用:"logout-button")%>当我单击此链接时,我的控制台显示以下输出:StartedGET"/users/profile"for127.0.0.1at2013-11-2520:45:53-0200ProcessingbyUsers::SessionsController#profileasHTMLUserLoad(0.7ms)SELECT"users".*FROM"users"

ruby-on-rails - 如何在不使用不同变量名的情况下更新 Rails 模型中实例方法中的属性?

我想在rails的实例方法中更新属性,而不必被迫更改传入的参数,这样我就可以利用rails的自动属性。这是一个例子。理想:status="some_new_status"person.update(status)classPerson我现在要做的:classPerson我明白在这个例子中这并不重要。但是,当我有复杂的更新方法时,如果我可以删除其中的一些代码,它会更清晰。 最佳答案 你应该使用内置的Rails方法:@person.update_attribute(:status,"SomeValue")#nocallbacktrigg

ruby-on-rails - Ruby on Rails - 缓存变量

我在Controller中设置了这两个变量。我如何缓存它们,这样它们就不会每次都与数据库通信,而只是第一次。@tablenutrients=Nutrient.find(:all)@columnnutrients=@tablenutrients.collect{|x|x.nutrient} 最佳答案 @djlumley说的。一般也可以配置使用ActiveSupport::Cache::Store显式存储您自己的自定义变量。然后您可以获取/设置缓存值,例如,像这样:@tablenutrients=Rails.cache.fetch("t

ruby - 带有字符串参数的 Sinatra 应用程序的 Heroku rake 任务失败

我刚刚将Sinatra应用程序部署到heroku,该应用程序包含两个rake任务:task:create_db,[:db_id,:db_name]task:destroy_db,[:db_id,:token]当我运行时herokurunrake-T在控制台中,Heroku打印以下响应:(in/app)rakecreate_db[db_id,db_name]#Creationcountdatabasetaskrakedestroy_db[db_id,token]#Destroydatabasetask但是当我运行时:herokurunrakecreate_db['test','testd

ruby-on-rails - 在什么情况下我应该使用实例变量而不是其他变量类型?

我正在使用RubyonRails3,我想知道在什么情况下我应该使用实例变量而不是其他变量类型,以及这些变量是否有安全原因。例子:#Usinganinstancevariable@accounts=Account.find(...)#Usinga"local"\"normal"variableaccount=Account.find(...) 最佳答案 一般来说,实例变量是局部的,并且持久存在于对象的实例中,而局部变量只是局部的,并且持久存在于函数/对象/block范围内。例如:classUserdefname@nameenddefn

ruby-on-rails - 如何在生产中的 ruby​​-on-rails 应用程序中运行 rake?

我正在尝试弄清楚如何在生产环境中部署我的ruby​​-on-rails应用程序。操作系统是ubuntu,应用程序使用Postgres。我已经设法部署了应用程序并能够登录等...但是某些功能无法正常工作(我是应用程序和Rails的新手)。该应用程序使用Elasticsearch,我已经安装了它并且服务正在运行(我可以通过http://localhost:9200访问该页面)。但是,当应用程序尝试访问Elasticsearch的组件时,出现错误。/app/lib/tasks目录下有一个rake文件,里面有几个文件,其中一个是elasticsearch.rakenamespace:appdo

ruby-on-rails - 在一行代码中初始化和递增变量

这是用ruby​​做的最干的方法吗?它将“n”初始化为“1”并随着循环的进行递增(并打印出来),因为这是我应用程序的一个View 最佳答案 您可以使用三元运算符:但是,根据您要执行的操作,我猜each_with_index会更合适 关于ruby-on-rails-在一行代码中初始化和递增变量,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1150658/